// 导入 http 模块
import http from 'wechat-http'
// 基础路径
http.baseURL = 'https://live-api.itheima.net'

//配置及请求拦截器
http.intercept.request = function (options) {
  //扩展头信息
  const defaultHeader = {}
  //身份认证
  defaultHeader.Authorization = 'Bearer ' + getApp().token
  // 与默认头信息合并
  options.header = Object.assign({}, defaultHeader, options.header)
  // 处理后的请求参数
  return options
}

//配置响应拦截器
http.intercept.response = async function ({ data, config }) {
  //如果状态码为401，则表明token已失效
  if (data.code === 401) {
    //获取应用实例对象来读取refreshToken
    const app = getApp
    // console.log(app.refreshToken)
    // 1.3 状态为 401 且接口为 /refreshToken 表明 refreshToken 也过期了
    if (config.url.includes('/refreshToken')) {
      // 获取当前页面的路径，保证登录成功后能跳回到原来页面
      const pageStack = getCurrentPages()
      const currentPage = pageStack.pop()
      const redirectURL = currentPage.route
      // 跳由跳转（登录页面）
      return wx.redirectTo({
        url: '/pages/login/index?redirectURL=/' + redirectURL,
      })
    }
    // 1.1 调用接口获取新的 token
    const res = await http({
      url: '/refreshToken',
      method: 'post',
      header: {
        Authorization: 'Bearer ' + app.refreshToken,
      },
    })
    //检测接口是否调用成功
    if (res.code !== 10000) return wx.utils.toast('更新token失败!')
    //重新存储新的token
    app.setToken('token', ras.data.token)
    app.setToken('refreshToken'.res.data.refreshToken)

    // 1.2 获取到原来接口请求的参数
    config = Object.assign(config, {
      header: {
        // 更新后的 token
        Authorization: 'Bearer ' + res.data.token,
      },
    })
    // 重新发请求
    return http(config)
  }
  // 只保留data数据，其它的都过滤掉
  return data
}

// 挂载到全局对象
wx.http = http
// 普通的模块导出
export default http
